/* 
 * PROJECT: NyARToolkitCS
 * --------------------------------------------------------------------------------
 * This work is based on the original ARToolKit developed by
 *   Hirokazu Kato
 *   Mark Billinghurst
 *   HITLab, University of Washington, Seattle
 * http://www.hitl.washington.edu/artoolkit/
 *
 * The NyARToolkitCS is Java edition ARToolKit class library.
 * Copyright (C)2008-2009 Ryo Iizuka
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 * 
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 * 
 * For further information please contact.
 *	http://nyatla.jp/nyatoolkit/
 *	<airmail(at)ebony.plala.or.jp> or <nyatla(at)nyatla.jp>
 * 
 */
namespace jp.nyatla.nyartoolkit.cs.core
{




    /**
     * このクラスは、主成分分析関数のインタフェイスを定義します。
     * 主成分分析関数は、ARToolKitの輪郭線の直線化処理で使う機能です。
     */
    public interface INyARPca2d
    {
        /**
         * この関数は、i_v1とi_v2ペアの値を主成分分析して、o_evec,o_ev,o_meanへ値を返します。
         * 引数の詳細な意味はまだ調べていません。
         * @param i_v1
         * 修正分析する値の配列（通常X座標）
         * @param i_v2
         * 修正分析する値の配列（通常Y座標）
         * @param i_number_of_point
         * 配列中の有効な値の長さ
         * @param o_evec
         * 出力値
         * @param o_ev
         * 出力値
         * @param o_mean
         * 出力値
         * @
         */
        void pca(double[] i_v1, double[] i_v2, int i_number_of_point, NyARDoubleMatrix22 o_evec, double[] o_ev, double[] o_mean);
        //	/**
        //	 * カメラ歪み補正つきのPCA
        //	 * @param i_x
        //	 * @param i_y
        //	 * @param i_start
        //	 * @param i_number_of_point
        //	 * @param i_factor
        //	 * @param o_evec
        //	 * @param o_mean
        //	 * @
        //	 */
        //	public void pcaWithDistortionFactor(int[] i_x,int[] i_y,int i_start,int i_number_of_point,INyARCameraDistortionFactor i_factor,NyARDoubleMatrix22 o_evec,NyARDoublePoint2d o_ev, NyARDoublePoint2d o_mean);
    }
}
